home *** CD-ROM | disk | FTP | other *** search
/ Games of Daze / Infomagic - Games of Daze (Summer 1995) (Disc 1 of 2).iso / x2ftp / msdos / libs / tge132 / quickref.doc < prev    next >
Text File  |  1994-05-21  |  27KB  |  462 lines

  1.  
  2.                           TGE 1.32 Quick Reference
  3.                   Copyright (c) 1994 by Matthew Hildebrand
  4.  
  5.  
  6. Initialization routines:
  7. =======================
  8.  
  9.   loadGraphDriver             Load a graphics driver.
  10.                               int loadGraphDriver(char *filename);
  11.   initGraphics                Initialize graphics mode.
  12.                               void initGraphics(void);
  13.   deInitGraphics              Initialize 80x25 colour text mode.
  14.                               void deInitGraphics(void);
  15.  
  16. Graphics primitives:
  17. ===================
  18.  
  19.   putPixel                    Place a single pixel on-screen.
  20.                               void putPixel(int x, int y, unsigned colour);
  21.   getPixel                    Get a single pixel from the screen.
  22.                               unsigned getPixel(int x, int y);
  23.   line                        Draw a line joining two points.
  24.                               void line(int x1, int y1, int x2, int y2,
  25.                                 unsigned colour);
  26.   horizLine                   Draw a horizontal line joining two points.
  27.                               void horizLine(int y, int x1, int x2,
  28.                                 unsigned colour);
  29.   vertLine                    Draw a vertical line joining two points.
  30.                               void vertLine(int x, int y1, ing y2, unsigned
  31.                                 colour);
  32.   drawRect                    Draw a regtangle outline.
  33.                               void drawRect(int ulx, int uly, int lrx, int
  34.                                 lry, unsigned colour);
  35.   filledRect                  Draw a filled rectangle.
  36.                               void filledRect(int ulx, int uly, int lrx,
  37.                                 int lry, unsigned colour);
  38.   ellipse                     Draw an ellipse outline.
  39.                               void ellipse(int x, int y, int wide, int
  40.                                 deep, unsigned colour);
  41.   filledEllipse               Draw a filled ellipse.
  42.                               void filledEllipse(int x, int y, int wide,
  43.                                 int deep, unsigned colour);
  44.   circle                      Draw a circle outline.
  45.                               void circle(int x, int y, int radius,
  46.                                 unsigned colour);
  47.   filledCircle                Draw a filled circle.
  48.                               void filledCircle(int x, int y, int radius,
  49.                                 unsigned colour);
  50.   clearGraphics               Clear the entire screen.
  51.                               void clearGraphics(unsigned colour);
  52.   fillRegion                  Floodfill a region of the screen with the
  53.                                 specified colour.
  54.                               void fillRegion(int x, int y, unsigned
  55.                                 colour);
  56.  
  57. Image-related functions:
  58. =======================
  59.  
  60.   putImage                    Put an image on-screen.
  61.                               void putImage(int x, int y, void *image);
  62.   putImageInv                 Put an image on-screen, treating zero pixels
  63.                                 as transparent.
  64.                               void putImageInv(int x, int y, void *image);
  65.   getImage                    Get an image from the screen.
  66.                               void getImage(int ulx, int uly, int lrx, int
  67.                                 lry, void *image);
  68.   imageSize                   Determine the amount of memory required to
  69.                                 store an image.
  70.                               unsigned long imageSize(int ulx, int uly, int
  71.                                 lrx, int lry);
  72.   imageSizeDim                Determine the amount of memory required to
  73.                                 store an image.
  74.                               unsigned long imageSizeDim(unsigned wide,
  75.                                 unsigned deep);
  76.   putHorizLine                Place one horizontal line of image data
  77.                                 on-screen.
  78.                               void putHorizLine(int y, int xOff, int
  79.                                 lineLen, void *buf);
  80.   putHorizLineInv             Place one horizontal line of image data
  81.                                 on-screen, treating zero pixels as
  82.                                 transparent.
  83.                               void putHorizLineInv(int y, int xOff, int
  84.                                 lineLen, void *buf);
  85.   getHorizLine                Get one horizontal line of image data from
  86.                                 the screen.
  87.                               void getHorizLine(int y, int xOff, int
  88.                                 lineLen, void *buf);
  89.   putHorizLine                Place one vertical line of image data
  90.                                 on-screen.
  91.                               void putVertLine(int x, int YOff, int
  92.                                 lineLen, void *buf);
  93.   putHorizLineInv             Place one vertical line of image data
  94.                                 on-screen, treating zero pixels as
  95.                                 transparent.
  96.                               void putVertLineInv(int x, int yOff, int
  97.                                 lineLen, void *buf);
  98.   getHorizLine                Get one vertical line of image data from the
  99.                                 screen.
  100.                               void getVertLine(int x, int yOff, int
  101.                                 lineLen, void *buf);
  102.   scaleBitmap                 Scale a bitmap.
  103.                               void *scaleBitmap(void *srcImage, unsigned
  104.                                 newWide, unsigned newDeep, void
  105.                                 *destImage);
  106.   imageWidth                  Return the width of an image.
  107.                               unsigned imageWidth(void *image);
  108.   imageHeight                 Return the height of an image.
  109.                               unsigned imageHeight(void *image);
  110.  
  111. Palette-related routines:
  112. ========================
  113.  
  114.   setPaletteReg               Set a single palette register.
  115.                               void setPaletteReg(unsigned palReg, unsigned
  116.                                 char red, unsigned char green, unsigned
  117.                                 char blue);
  118.   getPaletteReg               Get a single palette register.
  119.                               void getPaletteReg(unsigned palReg, unsigned
  120.                                 char *red, unsigned char *green, unsigned
  121.                                 char *blue);
  122.   setBlockPalette             Set a block of palette registers.
  123.                               void setBlockPalette(unsigned firstReg,
  124.                                 unsigned lastReg, void *data);
  125.   getBlockPalette             Get a block of palette registers.
  126.                               void getBlockPalette(unsigned firstReg,
  127.                                 unsigned lastReg, void *data);
  128.   colourCloseTo               Find a colour which closely matches the
  129.                                 specified 24-bit colour.
  130.                               unsigned colourCloseTo(unsigned char red,
  131.                                 unsigned char green, unsigned char blue);
  132.   colourCloseToX              Find a colour which closely matches the
  133.                                 specified 24-bit colour, excluding one
  134.                                 colour from the search.
  135.                               unsigned colourCloseToX(unsigned char red,
  136.                                 unsigned char green, unsigned char blue,
  137.                                 unsigned colourExclude);
  138.   fadePalette                 Fade one palette into another.
  139.                               int fadePalette(unsigned step, void *inPal,
  140.                                 void *outPal, void *targetPal);
  141.   greyPalette                 Produce a greyscale version of a palette.
  142.                               void greyPalette(void *inPal, void *outPal);
  143.   rotatePalette               Rotate a palette.
  144.                               void rotatePalette(int howMuch, void *inPal,
  145.                                 void *outPal);
  146.   promotePalette              Promote a 6-bit palette to 8-bit.
  147.                               void promotePalette(void *pal);
  148.   demotePalette               Demote an 8-bit palette to 6-bit.
  149.                               void demotePalette(void *pal);
  150.  
  151. Viewports and clipping:
  152. ======================
  153.  
  154.   setInputViewport            Set the defining coordinates of the input
  155.                                 viewport.
  156.                               void setInputViewport(int ulx, int uly, int
  157.                                 lrx, int lry);
  158.   setOutputViewport           Set the defining coordinates of the output
  159.                                 viewport.
  160.                               void setOutputViewport(int ulx, int uly, int
  161.                                 lrx, int lry);
  162.   setViewports                Set the defining coordinate of the input and
  163.                                 the output viewports.
  164.                               void setViewports(int ulx, int uly, int lrx,
  165.                                 int lry);
  166.   getInputViewport            Get the defining coordinates of the input
  167.                                 viewport.
  168.                               void getInputViewport(int *ulx, int *uly, int
  169.                                 *lrx, int *lry);
  170.   getOutputViewport           Get the defining coordinates of the output
  171.                                 viewport.
  172.                               void getOutputViewport(int *ulx, int *uly,
  173.                                 int *lrx, int *lry);
  174.   clipRect                    Clip a rectangle to within the current output
  175.                                 viewport.
  176.                               int clipRect(int *x1, int *y1, int *x2, int
  177.                                  *y2);
  178.   clipLine                    Clip a line to within the current output
  179.                                 viewport.
  180.                               int clipLine(int *x1, int *y1, int *x1, int
  181.                                 *y2);
  182.   clipInputPoint              Return a flag indicating whether or not the
  183.                                 specified coordinates lie within the
  184.                                 current input viewport.
  185.                               int clipInputPoint(int x, int y);
  186.   clipOutputPoint             Return a flag indicating whether or not the
  187.                                 specified coordinates lie within the
  188.                                 current output viewport.
  189.                               int clipOutputPoint(int x, int y);
  190.   pointOnScreen               Return a flag indicating whether or not the
  191.                                 specified coordinates lie on-screen.
  192.                               int pointOnScreen(int x, int y);
  193.  
  194. Virtual screens:
  195. ===============
  196.  
  197.   makeVirtScreen              Allocate memory for a virtual screen; can
  198.                                 also be used to allocate memory for an
  199.                                 image.
  200.                               void *makeVirtScreen(unsigned wide, unsigned
  201.                                 deep);
  202.   setGraphicsAddr             Set the location upon which graphics input
  203.                                 and output will both be performed.  Use
  204.                                 NULL for the screen, or a pointer to the
  205.                                 virtual screen to use.
  206.                               void setGraphicsAddr(void *addr);
  207.   setGraphicsInputAddr        Set the location upon which graphics input
  208.                                 will be performed.  Use NULL for the
  209.                                 screen, or a pointer to the virtual screen
  210.                                 to use.
  211.                               void setGraphicsInputAddr(void *addr);
  212.   setGraphicsOutputAddr       Set the location upon which graphics output
  213.                                 will be performed.  Use NULL for the
  214.                                 screen, or a pointer to the virtual screen
  215.                                 to use.
  216.                               void setGraphicsOutputAddr(void *addr);
  217.   getGraphicsInputAddr        Get the location upon which graphics input
  218.                                 will be performed.  Returns NULL for the
  219.                                 screen, or a pointer to the virtual screen
  220.                                 being used.
  221.                               void *getGraphicsInputAddr(void);
  222.   getGraphicsOutputAddr       Get the location upon which graphics output
  223.                                 will be performed.  Returns NULL for the
  224.                                 screen, or a pointer to the virtual screen
  225.                                 being used.
  226.                               void *getGraphicsOutputAddr(void);
  227.  
  228. Output modes:
  229. ============
  230.  
  231.   setGraphicsOutputMode       Select the output mode to use:  TGE_COPY_PUT,
  232.                                 TGE_AND_PUT, TGE_NOT_PUT, TGE_OR_PUT, or
  233.                                 TGE_XOR_PUT.
  234.                               void setGraphicsOutputMode(int mode);
  235.  
  236. Graphics files:
  237. ==============
  238.  
  239.   loadPalFile                 Load a palette data file.
  240.                               void *loadPalFile(char *filename, void
  241.                                 *addr);
  242.   savePalFile                 Save a palette data file.
  243.                               int savePalFile(char *filename, void *pal);
  244.   loadRawFile                 Load a RAW image file into memory.
  245.                               void *loadRawFile(char *filename);
  246.   saveRawFile                 Save a RAW image file to disk.
  247.                               int saveRawFile(char *filename, void *image);
  248.   displayRawFile              Display a RAW image file.
  249.                               int displayRawFile(int x, int y, char
  250.                                 *filename);
  251.   loadPcxFilePal              Load the palette from a PCX image file.
  252.                               void *loadPcxFilePal(char *filename, void
  253.                                 *addr);
  254.   loadPcxFile                 Load a PCX image file, and its palette if
  255.                                 requested, into memory.
  256.                               void *loadPcxFile(char *filename, char
  257.                                 *palette);
  258.   displayPcxFile              Display a PCX image file.
  259.                               int displayPcxFile(int x, int y, char
  260.                                 *filename);
  261.  
  262. Variable-size fonts:
  263. ===================
  264.  
  265.   VariableFont::load          Load a font from disk.
  266.                               int VariableFont::load(char *filename);
  267.   VariableFont::put           Put a string or character on-screen.
  268.                               void VariableFont::put(int x, int y, char
  269.                                 ch);
  270.                               void VariableFont::put(int x, int y, char
  271.                                 *ch);
  272.   VariableFont::width         Find the width of a string or character.
  273.                               unsigned VariableFont::width(char *string);
  274.                               unsigned VariableFont::width(char ch);
  275.   VariableFont::height        Find the height of a string or character.
  276.                               unsigned VariableFont::height(char *string);
  277.                               unsigned VariableFont::height(char ch);
  278.   VariableFont::maxWIdth      Return the width of the widest character.
  279.                               unsigned VariableFont::maxWidth(void);
  280.   VariableFont::maxHeight     Return the height of the tallest character.
  281.                               unsigned VariableFont::maxHeight(void);
  282.   VariableFont::matchColours  Match font colours to current palette.
  283.                               void VariableFont::matchColours(void);
  284.   VariableFont::palette       Get or set the entire font palette, or a
  285.                                 portion of it.
  286.                               void VariableFont::palette(void *data);
  287.                               void *VariableFont::palette(void);
  288.                               void VariableFont::palette(unsigned char
  289.                                 palReg, unsigned char red, unsigned char
  290.                                 green, unsigned char blue);
  291.                               void VariableFont::palette(unsigned char
  292.                                 palReg, unsigned char *red, unsigned char
  293.                                 *green, unsigned char *blue);
  294.   VariableFont::spacing       Get or set the current spacing value.
  295.                               unsigned VariableFont::spacing(void);
  296.                               void VariableFont::spacing(unsigned
  297.                                 numPixels);
  298.  
  299. Fixed-size fonts:
  300. ================
  301.  
  302.   FixedFont::load             Load a font from disk.
  303.                               int FixedFont::load(char *filename);
  304.   FixedFont::FixedFont        Initialize a FixedFont instance.
  305.                               FixedFont::FixedFont(unsigned char
  306.                                 foreground=1, unsigned char background=0);
  307.   FixedFont::width            Find the width of a string or character.
  308.                               unsigned FixedFont::width(char *string);
  309.                               unsigned FixedFont::width(char ch);
  310.   FixedFont::maxWidth         Return the width of the widest character.
  311.                               unsigned FixedFont::maxWidth(void);
  312.   FixedFont::height           Find the height of a string or character.
  313.                               unsigned FixedFont::height(char *string);
  314.                               unsigned FixedFont::height(char ch);
  315.   FixedFont::maxHeight        Return the height of the tallest character.
  316.                               unsigned FixedFont::maxHeight(void);
  317.   FixedFont::put              Put a string or character on-screen.
  318.                               void FixedFont::put(int x, int y, char ch);
  319.                               void FixedFont::put(int x, int y, char *ch);
  320.   FixedFont::foreground       Get or set the foreground colour.
  321.                               unsigned FixedFont::foreground(void);
  322.                               void FixedFont::foreground(unsigned colour);
  323.   FixedFont::background       Get or set the background colour.
  324.                               unsigned FixedFont::background(void);
  325.                               void FixedFont::background(unsigned colour);
  326.  
  327. Mouse-related functions:
  328. =======================
  329.  
  330.   initNewMouse                Initialize the new mouse handler.
  331.                               void initNewMouse(void);
  332.   deInitNewMouse              Deactivate the new mouse handler.
  333.                               void deInitNewMouse(void);
  334.   enableNewMouse              Re-enable the new mouse handler following a
  335.                                 call to disableNewMouse().
  336.                               void enableNewMouse(void);
  337.   disableNewMouse             Temporarily deactive the new mouse handler,
  338.                                 to be reactivated later by a call to
  339.                                 enableNewMouse().
  340.                               void disableNewMouse(void);
  341.   setupMousePointer           Select a mouse pointer bitmap.  This function
  342.                                 requires that the new mouse handler be
  343.                                 installed.
  344.                               void setupMousePointer(int pointerNum);
  345.   setPointerColours           Update the colours used to compose the mouse
  346.                                 pointer.
  347.                               void setPointerColours(void);
  348.   resetMouse                  Reset the mouse driver and hardware.  Returns
  349.                                 non-zero if a mouse driver is available.
  350.                               int resetMouse(void);
  351.   getButtonsMouse             Return the number of buttons on the mouse.
  352.                               int getButtonsMouse(void);
  353.   showMouse                   Show the mouse pointer.
  354.                               void showMouse(void);
  355.   hideMouse                   Hide the mouse pointer.
  356.                               void hideMouse(void);
  357.   getPosMouse                 Get the current mouse pointer position.
  358.                               void getPosMouse(int *x, int *y);
  359.   setPosMouse                 Set the mouse pointer position.
  360.                               void setPosMouse(unsigned x, unsigned y);
  361.   leftButtonMouse             Return non-zero if the left button is down.
  362.                               int leftButtonMouse(void);
  363.   rightButtonMouse            Return non-zero if the right button is down.
  364.                               int rightButtonMouse(void);
  365.   centerButtonMouse           Return non-zero if the center button is down.
  366.                               int centerButtonMouse(void);
  367.   buttonPressMouse            Return the number of times the specified
  368.                                 button has been pressed since the last call
  369.                                 to this function (with the same button
  370.                                 parameter), and store the coordinates of
  371.                                 the last press.
  372.                               unsigned buttonPressMouse(unsigned button,
  373.                                 int *x, int *y);
  374.   buttonReleaseMouse          Return the number of times the specified
  375.                                 button has been released since the last
  376.                                 call to this function (with the same button
  377.                                 parameter), and store the coordinates of
  378.                                 the last release.
  379.                               unsigned buttonPressMouse(unsigned button,
  380.                                 int *x, int *y);
  381.   setHorizLimitsMouse         Set the maximum and minimum horizontal limits
  382.                                 for the mouse pointer.
  383.                               void setHorizLimitsMouse(unsigned min,
  384.                                 unsigned max);
  385.   setVertLimitsMouse          Set the maximum and minimum vertical limits
  386.                                 for the mouse pointer.
  387.                               void setVertLimitsMouse(unsigned min,
  388.                                 unsigned max);
  389.   setPointerMouse             Set the shape of the mouse pointer.  This
  390.                                 function can only select 256-colour bitmaps
  391.                                 when the new mouse handler is installed.
  392.                               void setPointerMouse(int xOff, int yOff, void
  393.                                 *image);
  394.   getSaveSizeMouse            Return the size of the buffer necessary to
  395.                                 store the state of the mouse driver.
  396.                               unsigned getSaveSizeMouse(void);
  397.   saveStateMouse              Save the current state of the mouse pointer.
  398.                               void saveStateMouse(void *buf);
  399.   restoreStateMouse           Restore a previously saved state of the mouse
  400.                                 pointer.
  401.                               void restoreStateMouse(void *buf);
  402.   setRatioMouse               Set the mouse sensitivity, in units of
  403.                                 mickeys per 8 pixels of pointer movement.
  404.                               void setRatioMouse(unsigned horiz, unsigned
  405.                                 vert);
  406.   getSensitivityMouse         Get the mouse sensitivity, in units of
  407.                                 mickeys per 8 pixels of pointer movement.
  408.                                 The mouse double speed threshold (the
  409.                                 minimum number of mickeys per second of
  410.                                 motion before pointer movement is doubled)
  411.                                 is retrieved as well.
  412.   softResetMouse              Reset the mouse driver, but not the mouse
  413.                                 hardware.
  414.                               void softResetMouse(void);
  415.   waitReleaseMouse            If the specified button is not already up,
  416.                                 wait until it is released, then return.
  417.                               void waitReleaseMouse(int button);
  418.  
  419. Virtual coordinate system:
  420. =========================
  421.  
  422.   VirtualCoord::VirtualCoord  Create an instance of the virtual coordinate
  423.                                 system object.
  424.                               VirtualCoord::VirtualCoord(void);
  425.                               VirtualCoord::VirtualCoord(unsigned virtMaxX,
  426.                                 unsigned virtMaxY, unsigned realMaxX,
  427.                                 unsigned realMaxY);
  428.   VirtualCoord::virtParams    Set or get the maximum virtual x- and
  429.                                 y-coordinates.
  430.                               void VirtualCoord::virtParams(unsigned
  431.                                 virtMaxX, unsigned virtMaxY);
  432.                               void VirtualCoord::virtParams(unsigned
  433.                                 *virtMaxX, unsigned *virtMaxY);
  434.   VirtualCoord::realParams    Set or get the maximum real x- and
  435.                                 y-coordinates.
  436.                               void VirtualCoord::realParams(unsigned
  437.                                 realMaxX, unsigned realMaxY);
  438.                               void VirtualCoord::realParams(unsigned
  439.                                 *realMaxX, unsigned *realMaxY);
  440.   VirtualCoord::realCoords    Calculate the real (x,y) coordinates given
  441.                                 the virtual coordinates.
  442.                               void VirtualCoord::realCoords(unsigned virtX,
  443.                                 unsigned virtY, unsigned *realX, unsigned
  444.                                 *realY);
  445.   VirtualCoord::realX         Calculate the real x-coordinate given the
  446.                                 virtual x-coordinate.
  447.                               unsigned VirtualCoord::realX(unsigned virtX);
  448.   VirtualCoord::realY         Calculate the real y-coordinate given the
  449.                                 virtual y-coordinate.
  450.                               unsigned VirtualCoord::realY(unsigned virtY);
  451.   VirtualCoord::virtCoords    Calculate the virtual (x,y) coordinates given
  452.                                 the real coordinates.
  453.                               void VirtualCoord::virtCoords(unsigned realX,
  454.                                 unsigned realY, unsigned *virtX, unsigned
  455.                                 *virtY);
  456.   VirtualCoord::virtX         Calculate the virtual x-coordinate given the
  457.                                 real x-coordinate.
  458.                               unsigned VirtualCoord::virtX(unsigned realX);
  459.   VirtualCoord::virtY         Calculate the virtual y-coordinate given the
  460.                                 real y-coordinate.
  461.                               unsigned VirtualCoord::virtY(unsigned realY);
  462.